package modelo.bd.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import modelo.bd.ConexionPool;
import modelo.bd.excepcion.DAOException;
import modelo.dominio.Planta;

public class PlantaDAO { //extends AbstractDAO<Planta> {

    private String query;

    protected synchronized List<Planta> select() throws DAOException {
        Connection conexion = null;
        PreparedStatement sentencia = null;
        ResultSet resultado = null;
        List<Planta> resultados = null;
        try {
            conexion = ConexionPool.getInstancia().getConexion();
            sentencia = conexion.prepareStatement(query);
            resultado = sentencia.executeQuery();
            resultados = new ArrayList<Planta>();
            while (resultado.next()) {
                Planta planta = new Planta();
                planta.setIdPlanta(resultado.getInt("ID_PLANTA"));
                planta.setNombre(resultado.getString("NOMBRE"));
                planta.setAbreviacion(resultado.getString("ABREVIACION"));
                resultados.add(planta);
            }
        } catch (SQLException ex) {
            throw new DAOException("1 PLDS-SQL " + ex.getMessage());
        } finally {
            try {
                if (resultado != null) {
                    resultado.close();
                }
                if (sentencia != null) {
                    sentencia.close();
                }
                if (conexion != null) {
                    conexion.close();
                }
            } catch (SQLException ex) {
                throw new DAOException("2 PLDS-SQL " + ex.getMessage());
            }
        }
        return resultados;
    }

    public List<Planta> selectAll() throws DAOException {
        query = "SELECT ID_PLANTA\n"
                + "      ,NOMBRE\n"
                + "      ,ABREVIACION "
                + "FROM SSMA_PLANTAS_T";
        return select();
    }

    public List<Planta> selectWhere(String condition) throws DAOException {
        query = "SELECT ID_PLANTA\n"
                + "      ,NOMBRE\n"
                + "      ,ABREVIACION "
                + "FROM SSMA_PLANTAS_T "
                + "WHERE " + condition;
        return select();
    }
}
